# -*- coding: UTF-8 -*-
#/*
# *      Copyright (C) 2011 Libor Zoubek
# *
# *
# *  This Program is free software; you can redistribute it and/or modify
# *  it under the terms of the GNU General Public License as published by
# *  the Free Software Foundation; either version 2, or (at your option)
# *  any later version.
# *
# *  This Program is distributed in the hope that it will be useful,
# *  but WITHOUT ANY WARRANTY; without even the implied warranty of
# *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# *  GNU General Public License for more details.
# *
# *  You should have received a copy of the GNU General Public License
# *  along with this program; see the file COPYING.  If not, write to
# *  the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
# *  http://www.gnu.org/copyleft/gpl.html
# *
# */
import os,re,sys,urllib,urllib2,traceback,cookielib,time,socket
from htmlentitydefs import name2codepoint as n2cp
import simplejson as json
UA='Mozilla/6.0 (Windows; U; Windows NT 5.1; en-GB; rv:1.9.0.5) Gecko/2008092417 Firefox/3.0.3'
LOG=2
sys.path.append( os.path.join ( os.path.dirname(__file__),'contentprovider') )
##
# initializes urllib cookie handler
def init_urllib():
    cj = cookielib.LWPCookieJar()
    opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(cj))
    urllib2.install_opener(opener)

def request(url,headers={}):
    debug('request: %s' % url)
    req = urllib2.Request(url,headers=headers)
    response = urllib2.urlopen(req)
    data = response.read()
    response.close()
    debug('len(data) %s' % len(data))
    return data

def post(url,data):
    postdata = urllib.urlencode(data)
    req = urllib2.Request(url,postdata)
    req.add_header('User-Agent',UA)
    response = urllib2.urlopen(req)
    data = response.read()
    response.close()
    return data

def icon(name):
    return 'https://github.com/lzoubek/xbmc-doplnky/raw/dharma/icons/'+name

def substr(data,start,end):
    i1 = data.find(start)
    i2 = data.find(end,i1)
    return data[i1:i2]

def _create_plugin_url(params,plugin=sys.argv[0]):
    url=[]
    for key in params.keys():
        value = decode_html(params[key])
        value = value.encode('ascii','ignore')
        url.append(key+'='+value.encode('hex',)+'&')
    return plugin+'?'+''.join(url)


def save_to_file(url,file):
    try:
        return save_data_to_file(request(url))
    except:
        traceback.print_exc()

def save_data_to_file(data,file):
    try:
        f = open(file,'wb')
        f.write(data)
        f.close()
        return True
    except:
        traceback.print_exc()
def read_file(file):
    if not os.path.exists(file):
        return ''
    f = open(file,'r')
    data = f.read()
    f.close()
    return data

def _substitute_entity(match):
    ent = match.group(3)
    if match.group(1) == '#':
        # decoding by number
        if match.group(2) == '':
            # number is in decimal
            return unichr(int(ent))
        elif match.group(2) == 'x':
            # number is in hex
            return unichr(int('0x'+ent, 16))
    else:
        # they were using a name
        cp = n2cp.get(ent)
        if cp: return unichr(cp)
        else: return match.group()

def decode_html(data):
    try:
        if not type(data) == unicode:
            data = unicode(data,'utf-8',errors='ignore')
        entity_re = re.compile(r'&(#?)(x?)(\w+);')
        return entity_re.subn(_substitute_entity,data)[0]
    except:
        traceback.print_exc()
        print [data]
        return data

try:
    import xbmc
    def debug(text):
        xbmc.log(str([text]),xbmc.LOGDEBUG)

    def info(text):
        xbmc.log(str([text]))

    def error(text):
        xbmc.log(str([text]),xbmc.LOGERROR)
except:
    def debug(text):
        if LOG>1:
            print('[DEBUG] '+str([text]))
    def info(text):
        if LOG>0:
            print('[INFO] '+str([text]))
    def error(text):
        print('[ERROR] '+str([text]))


_diacritic_replace= {u'\u00f3':'o',
u'\u0213':'-',
u'\u00e1':'a',
u'\u010d':'c',
u'\u010c':'C',
u'\u010f':'d',
u'\u010e':'D',
u'\u00e9':'e',
u'\u011b':'e',
u'\u00ed':'i',
u'\u0148':'n',
u'\u0159':'r',
u'\u0161':'s',
u'\u0165':'t',
u'\u016f':'u',
u'\u00fd':'y',
u'\u017e':'z'
}

def replace_diacritic(string):
    ret = []
    for char in string:
        if char in _diacritic_replace:
            ret.append(_diacritic_replace[char])
        else:
            ret.append(char)
    return ''.join(ret)


def params(url=None):
    if url == None:
        url = sys.argv[2]
    param={}
    paramstring=url
    if len(paramstring)>=2:
        params=url
        cleanedparams=params.replace('?','')
        if (params[len(params)-1]=='/'):
            params=params[0:len(params)-2]
        pairsofparams=cleanedparams.split('&')
        param={}
        for i in range(len(pairsofparams)):
            splitparams={}
            splitparams=pairsofparams[i].split('=')
            if (len(splitparams))==2:
                param[splitparams[0]]=splitparams[1]
    for p in param.keys():
        param[p] = param[p].decode('hex')
    return param
